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MANAGING OBJECTS AND SHARING INFORMATION 



AMONG COMMUNITIES 



FIELD OF THE INVENTION 

The present invention is in the general field of 
managing objects and sharing information among 
communities, such as sharing bookmarks of frequently used 
5 locations (URLs) among web surfers. 
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BACKGROUND OF THE INVENTION 

10 The Web is huge. Users often find locations (sites, 

home pages, URLs) which they feel are of potential future 
use. Finding their way to the same location again could be 
tricky , difficult and time consuming. Accordingly, surfers 
usually want to mark the web page of interest, making it 

is easier to find when necessary- These marks are usually 
referred to as bookmarks (also as favorites,, thumbnails, 
hotlists) - 

The traditional way to organized bookmarks is using a 
tree structure. Popular browsers (Netscape Communicator™, 

20 Netscape Navigator™ and Microsoft* 64 Internet Explorer) 
include a bookmark management tool, each using its own 
proprietary format for storing the bookmarks. Several 
stand-alone bookmark management tools have also been 
developed These tools allow users to design their own tree 

25 organization of bookmarks, and to enter bookmarks and 
manage them, as well as open them in the browser (when 
clicked) . The tree organization is a simple and well 
understood way, allowing each user to organize bookmarks 
for easy access based on personal preferences. 

30 These existing bookmark management tools with few 

exceptions noted later, are focused on helping an 
individual user rather than facilitating the sharing of 
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bookmarks among users. In order to share bookmarks, users 
typically send the URL's or bookmark files to each other 
(e.g. using e-mail)* This is clearly not a very efficient 
mechanism. Sharing of complete bookmark files is 
5 especially problematic as different tools {browsers) use 
different proprietary, incompatible formats. This is 
actually a problem even for (many) users who use multiple 
browsers and/or machines - e.g. users that have two 
operating systems or computers, and two different browsers 

10 will have four bookmark files. There are some utilities 
that purport to translate bookmark files among these 
different format s, but this procedure is burdensome and 
sometimes error prone 

Another common approach used to share URLs is to 

15 provide them as links on specially designed web pages , 
referred to as web indexes (or "lists of links") . Such 
indexes are now commonly provided in most web sites and 
even in many personal homepages. Indexes may focus on the 
interests of a particular individual or community/ on a 

20 particular subject, or be general- There are several 
large, mega-indexes which categorize "all the web" as a 
series of HTML pages, A well known example is YAHOO ! ™" 
Each index has its own tree structure, and typically 
offers two ways of locating URLs (i.e. bookmark); using a 

25 search utility (simple search in a database), or using the 
categorized folders. In the mega-indexes , users may also 
mark web pages to be indexed and suggest the appropriate 
folder. 



30 



There are several problems in sharing bookmarks using 
such indexes: 

■ The indexes are provided in special web sites, 
rather than as a local application and files; this 
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implies that access is substantially slower and 
less convenient, compared to a local bookmark 
management tool. Furthermore, this depends on 
connectivity to the index server* 
s ■ The same URL may be relevant to more than one 

folder; furthermore, different users may prefer 
different arrangement of folders (e.g. top level 
folder "music" and sub-folder "shopping" or vice 
versa) or simply a different name for folders (e.g. 
10 "find' 1 and "search") . The result is that relevant 

URLs are often spread cross multiple folders, as is 
known to every user of the popular indexes such as 
Yahoo 1™ 

■ Users often have bookmarks that they do not wish 
15 to share, being private (e.g. including 

passwords) or simply user specific* A common 
index server does not allow such features . 

Several different systems enable users to share 

20 personal bookmark collections: 

Keller et al. [KWCKM] introduced the WebTagger. 
WebTagger was designed as a personal and community 
bookmarking service/ running in a web server (as CGI 
program) . The system is a proxy based system that modifies 

25 each web page being browsed/ by adding buttons for 
categorizing the page, querying the database/ etc. To look 
up folders, the user needs to form a query, as there is no 
common or customized folder organization. Inter alia, 
There is no support for privacy or replication. 

30 Klark and Manber designed the Warmlist [KM] ♦ The 

application is based on sharing a common bookmark file 
using a shared file system (Unix™) , Users can insert their 
own bookmarks, organize them hierarchically (using the 
same tree), index them, and search the file for bookmarks. 
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Active Notebook (Torrance) allows users to label 
information with conceptual classifications and organized 
them into a taxonomy for later browsing and retrieval. The 
focus of Torrance's work is on clustering documents and 
5 identifying morphological concepts (keywords) . Torrance 
does not deal with aspects of sharing such as replication, 
privacy and user interface. 

Wittenberg et al. created the Group Asynchronous 
Browsing Server [WDHS] that collects and merges user's 

10 bookmarks and then displays these merged bookmarks in a 
standard web browser. Their approach is that when they 
find the same URL in two bookmark files, they give the 
user a link from the folder in one bookmark file to the 
folder of the other bookmark file. 

15 Collaborative filtering methods provide a means of 

selective information sharing by utilizing preference 
indicated by other users. These preferences might be 
inferred implicitly from the actions of others, or might 
be based on explicit user evaluation. See [GNOT], 

20 [SiteSeer] , [KRW ] , [KMMHGR] , 

Gifford et al, [see GJSO] provides for a semantic 
file system which is an information storage system that 
provides flexible associative access to the system 1 s 
contents by automatically extracting attributes from files 

25 with file type specific transducers. Associative access is 
provided by a conservative extension to existing 
tree-structured file system protocols, and by protocols 
that are designed specifically for content based access. 
Compatibility with existing file system protocols is 

30 provided by introducing the concept of a virtual 
directory. Virtual directory names are interpreted as 
queries , and thus provide flexible associative access to 
files and directories in a manner compatible with existing 
software. Rapid attribute-based access to file system 

35 contents is implemented by automatic extraction and 
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indexing of key properties of file system objects. The 
Semantic File System in accordance with the Gifford et aL 
publication supports various types of objects, such as 
documents, mails and other objects, 
5 Gopal et al, [see GM] provides for a new file system 

that combines name-based and content-based access to files 
at the same time. The design allows both methods to be 
used at any time, thus preserving the benefits of both. 
Users can create their own name spaces based on queries, 

10 on explicit path names, or on any combination interleaved 
arbitrarily. All regular file operations - such as adding, 
deleting, or moving files- are supported in the same way, 
and in addition/ query consistency is maintained and 
adapted to what the user is manually doing* One can add, 

15 remove or move results of queries, and in general handle 
them as if they were regular files , 

The specified Gifford et ai* and Gopal et al. 
publications offer an object -management system which does 
not aim at handling object sharing, however offer a 

20 management scheme, which supports handling of, say, data 
files, by assigning attributes to the specified data 
files, and enabling to query the data files by the 
attributes • For example, extracting all data files sent 
To "Smith". In a similar manner, the proposed approach may 

25 support also bookmark management. 

The proposed systems of the kind disclosed in Gifford 
et al. and Gopal et al, publications, have some inherent 
limitations. For one, the attributes that are assigned to 
the various objects are of static nature. (e.g. for 

30 letters the fields; From:, To: etc.)- In many real life 
applications the static nature of attributes is 
insufficient. Consider, for example, the specified 
bookmark: sharing application where a given bookmark is 
assigned with the attribute, say IBM, 'A given user may now 

35 decide that the specified bookmark should also be assigned 
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with the attribute, say security. Not only that a static 
attribute system would fall short in supporting such 
change (by this particular embodiment adding new attribute 
and assigning the so added attribute to an object), but 
5 obviously fails to propose a scheme for propagating this 
update among other members in the community. Thus, it 
would be expected that the specified bookmark would be 
reflected at other user views (associated with the same or 
different users) who already exploit the attribute 
10 s&cvrlty. 

There is, accordingly, a need in the art to provide a 
technique, which enables to manage and possibly share 
objects among users f and which substantially overcomes the 
limitation of hitherto known techniques. There is a 
15 further a need in the art to provide a system that enables 
to manage objects also in a single user environment. 

SUMMARY OF THE INVENTION 

The invention provides for a method for managing 
objects for at least one user, comprising: 
20 (a) providing a set of attributes; 

(b) providing a set of containers, each associated with 
attributes from among said set; 

(c) providing user interface for dynamically assigning 
attributes to said objects; 

25 (d) selectively displaying, through a user interface, at 
least one container; an object is displayed in said 
container if a condition is met; the condition is 
applied to at least the following: at least one of the 
attributes of the container and at least one of the 
30 attribute of the object. 

The invention further provides for a method for 
sharing objects among community of users; each user is 
associated with a respective set of attributes such that 
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at least one attribute is common to at least two of said 
users; the method comprising executing the following steps 
for each user in rhe community: 

(a) providing a user replica that includes objects that 
5 are assigned, each, with at least one attribute; 

(h) providing a set of containers associated, each, 

with attributes from among said set; 
(o) providing a user interface for generating an update 
in said replica; 
10 (d) submitting the update stipulated in step c to the 
replicas of selected users; 
<e) receiving at least one update from at least one user 
in the community and update said user replica with the 
so received update; and 
15 (f) selectively displaying, through a user interface, at 
least one container; an object from the replica is 
displayed in said container if a condition is met; the 
condition is applied to at least the following: at 
least one of the attributes of the container and at 
20 least one of the attribute of the object. 

Still further the invention provides for a system 
for managing objects for at least one user, comprising a 
processor and associated memory and display configured to 
perform the operations that include: 
25 (a) providing a set of attributes; 

(b) providing a set of containers, each associated with 
attributes from among said set; 

(c) providing user interface for dynamically assigning 
attributes to said objects ; 

30 <d) selectively displaying, through a user interface, at 
least one container; an object is displayed in said 
container if a condition is met; the condition is 
applied to at least the following: at least one of the 
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attributes of the container and at least one of the 
attribute of the object. 

The invention provides for a system for sharing 
objects among community of users; the system includes at 
5 least one server communicating through a network with 
users, each being associated with a processor and 
associated memory and display that includes a respective 
set of attributes such that at least one attribute is 
common to at least two of said users; the respective 
10 processor and associated memory and display are configured 
to executing the following steps that include: 

(a) providing a user replica that includes objects that 

are assigned, each, with at least one attribute; 
(h) providing a set of containers associated, each, 
15 with attributes from among said set; 

(c) providing a user interface for generating an update 
in said replica; 

(d) submitting through said at least one server the 
update stipulated in step c to the replicas of selected 

20 users; 

(e) receiving through said at least one server at least 
one update from at least one user in the community and 
update said user replica with the so received update; 
and 

25 (£) selectively displaying, through a user interface, at 
least one container; an object from the replica is 
displayed in said container if a condition is met; the 
condition is applied to at least the following: at 
least one of the attributes of the container and at 
30 least one of the attribute of the object * 

The invention further provides for a program storage 
device readable by machine, tangibly embodying a program 
of instructions executable by the machine to perform 
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method steps for managing objects for at least one user, 
comprising: 

(a) providing a set of attributes; 

(b) providing a set of containers, each associated with 
5 attributes from among said set; 

(c) providing user interface for dynamically assigning 
attributes to said objects; 

(d) selectively displaying, through a user interface, at 
least one container; an object is displayed in said 

10 container if a condition is met; the condition is 

applied to at least the following: at least one of the 
attributes of the container and at least one of the 
attribute of the object. 

The invention further provides for a computer 
is program product comprising a computer useable medium 
having computer readable program code embodied therein for 
managing objects for at least one user, the computer 
program product comprising: 

computer readable program code for causing the 
20 computer to provide a set of attributes ; 

computer readable program code for causing the 
computer to providing a set of containers, each 
associated with attributes from among said set; 

computer readable program code for causing the 
25 computer to provide user interface for dynamically 
assigning attributes to said objects; 

computer readable program code for causing the 
computer to selectively displaying, through a user 
interface, at least one container; an object is displayed 
30 in said container if a condition is met; the condition is 
applied to at least the following: at least one of the 
attributes of the container and at least one of the 
attributes of the object. 



35 
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A typical (but not exclusive) bookmark sharing 
application includes the following characteristics: 

• Common attributes: the community all uses the same 
5 set of attributes. Each user builds its own user 

interface, by this particular example tree of 
folders, associating attributes to each folder. Each 
bookmark is also assigned with attributes which are 
used to display the bookmark in the appropriate 
10 folders of each user (if a condition is met) . The 

list of attributes can be updated, e.g. new 
attributes can be inserted and/or others may be 
deleted. 

• Replication: a database of all bookmarks is kept in a 
15 server to which all users have access. Preferably, 

local replicas of this database are kept in each 
user's machine. The replication enables users Inter 
alia to work off-line (while not connected to a 
server), and provides much better performance. 

20 • Privacy: users may easily define some URLs (and 
possibly attributes) as private. Privately marked 
CJRLs are encrypted in the server and in the replicas 
of that user, so that access is possible only using 
the key of the user. Privacy may be regarded as an 

25 attribute that is associated with selected folders. 

Bookmarks can be dynamically assigned to folders and 
by the preferred embodiment they inherent the 
attributes of the folder. Thus bookmark that are 
assigned to private folders inherit the privacy 

30 attribute. Other attributes may be assigned to 

folders such as, for example, History signifying that 
bookmarks associated to this folder have just been 
recently used. Another non-limiting example, is Hot 
attribute associated to a folder that includes all 
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those bookmarks which have just been recently added 
to folders. 

* Simple, familiar view user interface: the 
implementation uses a familiar tree folder structure 
5 user interface, allowing the user to perform common 

operations with click and drop user interface. The 
approach resembles a known user interface/ such/ for 
example, in the MICROSOFT 3 * 1 folder explorer utility, 
and therefore reduces the time it takes to become 

10 familiar with the user interface. The drag and drop 

operation is utilized by one embodiment to assign 
attributes to bookmarks) . Having mapped the bookmark 
to a folder the attributes of the folder are 
automatically assigned to the bookmark. 

is • Display of bookmarks in folders through familiar user 
interface. As will be explained in greater detail 
below assignment of attributes to bookmarks, e.g. by 
drag and dropping the specified bookmark to a folder 
does not necessarily mean that the bookmark will be 

20 displayed in the specified folder. As will bo 

elaborated in greater detail below, In order for the 
bookmark to be displayed in the folder, it must meet 
a condition (s) that is (are) applied to the 
attributes of the container and the bookmark. 



25 



30 



It should be noted that the term user should not be 
construed in a narrow manner. Thus, for example, a given 
user may have two distinct user applications running on 
the same or different machines . 
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BRIEF DESCRIPTION OF THE DRAWINGS 

In order to understand the invention and to see how 
it may be carried out in practice, a preferred embodiment 
5 will now be described, by way of non-limiting example 
only, with reference to the accompanying drawings, in 
which : 

Figs, la^b illustrate sample user interface view 
represented as a tree of folders, in accordance with one 
10 embodiment of bookmark sharing application; 

Fig. 2 illustrates a block diagram of a generalised 
system architecture in accordance with the invention. 

Figs. 3a-d illustrate a user view before and after 
the insertion of an object; 
15 Figs. 4a-c illustrate an update sequence of operation 

in accordance with one embodiment of the invention; 

Fig. 5 illustrates an exemplary attributes dialog 
box, in accordance with on embodiment of the invention; 

Fig. 6 illustrates a user interface view in 
20 accordance with one embodiment of the invention; and 

Fig* 7 illustrates bookmark dialog box in accordance 
with one embodiment of the invention. 

DETAILED DESCRIPTION OF A PREFERRED EMBODIMENT 

Whilst, for simplicity, the discussion below 
25 pertains to a bookmark management and sharing 
application, the invention is by no means bound to 
bookmarks. Thus, bookmarks is only one out of many 
possible objects and accordingly other objects in 
addition or in lieu of the specified bookmarks, such as 
30 emails, files of various types, etc, or combination 
thereof . 
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Likewise, the description is mainly focused on tree 
of folders user interface, such as a Microsoft 2 * 1 File 
Explorer like structure. Folders are only a non-limiting 
example of a set of containers and a tree is only a 
5 non-limiting example of arranging the set of containers. 

A very popular interface for viewing bookmarks (as 
well as files, mail messages, etc,)/ is using a tree of 
folders, e.g. in accordance with the Microsoft™ file 
explorer user interface. In many applications, browsing 

10 the tree is a better way to look for the right bookmark, 
rather than doing a textual search in the database. 
However, organizing shared bookmarks into folders is 
difficult. The same URL may be relevant to more than one 
folder; furthermore, the different users may prefer a 

15 different arrangement of folders (e.g., one user prefers 
top level folder, "music" and sub-folder "shopping", 
whereas another user prefers the other way around, i,e, 
top level folder "shopping" and sub-f older "music") , or 
simply a different name for folders (e.g., "find" and 

20 "search") . 

A simple approach that purports to overcome this 
problem, is to decide on a fixed tree of folders used by 
all members of the community when entering bookmarks, 
possibly with some additional conventions. However, as 
25 explained above, such approach lacks flexibility, and it 
is hard to agree on commonly accepted and useful 
organization . 

In accordance with one aspect of the invention, there 
is provided a community of users that agree on a set of 
30 attributes- Each user can build his/her set of containers 
and associate attributes to each container. It should be 
noted that whilst, preferably, the set of attributes is 
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common to the users in the community, this is not 
necessarily always the case. Thus, users in the community 
may have a set of attributes, some of which are not 
necessarily shared by some or all of the other members in 
5 the community. 

In accordance with one embodiment of the invention 
there is provided a user interface for dynamically adding, 
deleting or updating attributes in the set. 

As will be explained in greater detail below, the 
10 attributes are used to display bookmarks in the 
appropriate folders of each user. 

By one embodiment, the user defines a set of 
attributes. In the case of community of users, each user 
in a community defines a set of attributes that is 

15 relevant to the community's interests. The set of 
attributes is finite and yet dynamic. The procedure of 
addition of new attributes is explained in great detail 
below. In the case of community of users this set of 
attributes may be regarded as the "language" of the 

20 community. 

The set of attributes is used to display bookmarks 
in, say tree of folders. A bookmark is displayed in a 
folder (or folders) if a condition is met. The condition 
is applied to at least the following: at least one of the 

25 attributes of the folder and at least one of the attribute 
of the bookmark. By a specific embodiment a bookmark is 
displayed in a folder if the bookmark and the folder share 
a common attribute. 

To this end, objects (bookmarks) are dynamically 
30 assigned with attributes through user interface. By a 
specific embodiment the attributes are dynamically 
assigned to bookmarks using "drag and drop" operation. By 
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this embodiment an object is mapped to a given container 
(folder) and inherits the attributes that are assigned to 
the specified container (folder) . 

For a better understanding, attention is now 
5 directed to Figs, 1A-B, illustrating a sample user 
interface represented as a tree of folders, in accordance 
with one embodiment of the invention. 

10 Thus, the user interface 11 in Fig. 1A represented as 

a tree of folders (for, say, a first user in the 
community, or a single user in a stand-alone environment) 
similar to the known Microsoft™ file Explorer tree 
representation* Each folder (e.g. "books" (12)) is 

15 associated with attributes and by this particular 
embodiment "shopping" and "book" (13) - In 

the user interface of Fig. 1A, attributes are embraced by 
square brackets. Sample folder tree 14 in Fig* IB 
represents the user interface for, say, a second user in 

20 the community. 

The list of URLs (or bookmarks) that corresponds to a 
given folder, are stored in the specified folder (not 
shown in Figs. 1A and IB), similar to files that belong 
to a given folder in the Windows Explorer utility. 

25 

The table below lists some examples of where bookmarks 
with specific attributes will be placed: 



IS999-013 17 



52/61 1*72 "ON LZ'-9l 00. 60/£0 



A +" +" "V A. ■! 't +• tM 


bainpis jl ree ± 


Sample Tree 2 


Q Vv ^\y\ y-v, *. ~, 

oiiopp JLily 


onopping 










Shopping , web, 
find 


Shopping, 
Find>Internet 


Shopping, Web>Shopping 
Web>Find 


Find, people 


Find>People 


People in the Web 


Find 


Find 


(Will not appear) 



By a specific embodiment of bookmark sharing, when a 
URL is inserted into a community database, the system 
5 creates a record that has three fields: 

• Key: The (3RL that the user wants to bookmark 

♦ Attributes: A set of attributes that is assigned to 

the URL's. Attributes are selected from a fixed set 
known to the community and maintained by the server. 

10 Each user may suggest additional attributes, and the 

server administrator decides whether or not the update 
(by this particular embodiment the so added 
attributes) will be submitted to the community. The 
display of bookmarks into folders is done according to 

15 their attributes, normally by applying a condition to 
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the attributes of the folder and the attributes of the 
bookmark. For example, a bookmark is displayed in a 
folder if they share a common attribute. It is 
therefore desirable that the community understands the 
5 attributes- Consequently, it would be desired 

(although not obligatory) that the bookmark sharing 
technique of the invention would be applicable for 
small to medium communities. 

By a specific embodiment, there are three types of 
10 attributes: 

• Global - an attribute that is shared throughout 
the community, 

• Private - an attribute that is private and used 
only by the user that inserted it. These 

15 attributes will not be submitted to other users in 

the community* 

• Submit - an attribute that a user feels should be 
added to the collection of attributes globally 
shared by the community. Initially, the attribute 

20 is local, but, as will be explained in greater 

detail below, the server can later change them 
into global attributes- 

• URL related data: Additional information 
describing the URL. The related data may be 

25 generated automatically. Automatically generated 

data includes e.g. the bookmark title, time of 
insertion, importance, owner of the data, expiration 
date, etc. 
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Viewing Bookmarks 



10 



15 



20 



25 



30 



After having assigned attributes to both the 
bookmarks and the folders the bookmarks can be displayed 
Bookmarks are displayed through user interface, as 
illustrated e.g. in Fig. 1, and are organized e.g., into a 
tree of folders. Each folder has a name and being assigned 
with one or more attributes (taken from the set of 
attributes). As described above, attributes are also 
assigned to each bookmark. By a preferred embodiment, if 
the folder contains a sub-folder, and a bookmark has also 
the attributes of the sub-folder, the bookmark is only 
displayed in the sub-folder (as a finer categorization). 
This logic is implemented by the following rule: 



A bookmark will appear'inTfoT^r iT^Tonly if: 

• The bookmark's attributes contain the folder 

• The bookmark does not appear in any folder contained in this folder. 



As specified above, a bookmark is displayed in a 
folder if a condition is met. By this specific example 
the condition includes a sub-condition that stipulates 
that an attribute (at least one) assigned to the bookmark 
is contained in the attributes of the folder in which the 
bookmark is displayed. The condition further includes a 
sub-condition stipulated that the bookmark does not 
appear in any folder contained in this folder. 

The specified condition (s) and the sub-conditions 
thereof are, of course, not obligatory. Condition (s) and 
sub-condition (s) which stipulate what bookmarks will be 
displayed in what folders may be determined in accordance 
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with the particular application, all as required and 
appropriate . 

As specified above, in accordance with the invention 
there is provided a user interface for enabling dynamic 
5 assignment of attributes to objects. In accordance with a 
preferred embodiment/ using the same interface of Fig. 1, 
a drag and drop operation is used in order to 
insert /delete a bookmark. Thus, by this embodiment upon 
dragging a URL into a folder, the URL inherits the 
10 attributes of that folder. The operation is simple and 
intuitive. 

Notice that the result of such a single drag and drop 
of a URL into a folder, may reside in mapping the URL 
into multiple folders having a subset of these 

15 attributes. The URL may be dragged to additional folders, 
thereby being assigned with more attributes as necessary. 
For example, dragging a bookmark to the folder books (12) 
in the user interface illustrated in Fig- 1A, will 
automatically assign the attributes shopping and book 

20 (13) that are associated with this folder* The side 
effect of this operation is that this bookmark will also 
be mapped to the folder books (15) in user interface (14) 
considering that the folder books (IS) is also associated 
with attributes shopping and book (16) . A user may also 

25 assign bookmark related data to a URL, such as level of 
importance, expiration date, etc- The submission of the 
specified update (from user interface (11)) to user 
interface (14) will be discussed in greater detail below. 

The consequence of a single drag and drop operation 
30 is further exemplified with reference to Fig. 3- Fig. 3A 
illustrates five user views (31 to 35) • Having dragged 
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and dropped item 1 - say, a bookmark (36 in Fig, 3B) to 
View 5, Item 2 is assigned with the 1,2, and 4, 
Consequently, Item 1 is automatically assigned to view 1 
(31 -due to attributes 1 and 2), view 3 {33 -due to 
5 attribute 4) and view 4 (34 -due to attribute 1) , The 
update among the views is implemented in a manner that is 
described in detail below* 

All users define their own individual tree of folders 
user interface. As mentioned above, the tree defines the 

10 folders used by the user to organize and subsequently 
display bookmarks. Users may edit their tree at any time. 
These operations are done on the user's machine and no 
one (i.e. other users or the server) can see the user 
tree view. In accordance with a preferred embodiment, the 

15 ' system of the invention includes a server that maintains 
the database of attributes and bookmarks; each member of 
the community runs a user application. The users are 
allowed to work off-line (i.e. a client can work even if 
the server is not running) . In order to do so, the client 

20 must have a local replica of the data collected by the 
server. This is done using a data replication scheme 
between the client and the server. The replication 
protocol includes, by one embodiment, the following 
steps : 

25 • Initialization: Upon initialization, the user 

registers with the server and receives the 
current database and the community attribute 
list. The database may be organized in any known 
per se technique, e.g. relational database. 

30 • Updates: From time to time, at intervals 

determined by its internal clock, the client 
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sends the server updates and receives updated 
information that was sent to the server by other 
users , 

In accordance with a preferred embodiment/ the 
5 update protocol concerns preferably only incremental 
updates, and therefore keeps communication overhead at a 
minimum. Because the user starts with the same database 
as the server and all client updates are done in the 
order specified by the server, both the user and server 

10 database contain the same information after the update 
process. This is the reason why incremental updates are 
sufficient. Note that if two users update the same 
bookmark, the updated information is determined by the 
last user to perform an update* 

15 Figs. 4a-<s illustrate an update sequence of operation 

in accordance with one embodiment of the invention. Thus, 
Fig, 4a illustrates three user replica (41-43) interlinked 
to a database server (44) - Each replica includes objects 
that are assigned with attributes* The assignments of 

20 attributes to objects were discussed above and will be 
further discussed below. By this embodiment, the replica 
may further include the user set of attribute and also the 
user set of containers. Considering, for example, that a 
user updates his replica with an additional object (45 in 

25 Fig, 4B> which he wishes to submit to other users, the 
update (by this particular example addition of an object) 
is submitted (46 and 47 in Fig. 4C) to the user replicas 
(42 and 43) through the server (44) . The update is 
received in each replica, and when the user invokes the 

30 user interface for displaying objects in containers, the 
specified update is displayed, if applicable. Thus if the 
attribute (s) of the specified object and those of 
container (s) meet the condition, e.g. of the kind 
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specified above the object is displW^ tffe- 
container (s) , 



10 



15 



Privacy : 

When a community shares information, it is important 
to maintain user privacy. Most users in a community, 
although they would like to share information, need to 
keep certain data private. 

There follows a non-limiting embodiment where 
privacy is implemented. By this embodiment, the server 
stores all of the community data, therefore, certain 
information must be kept private from the server as well 
Users can decide whether or not information will be 
shared or kept private. 



Upon utilization, clients choose a password to 
protect their private data. The application then selects 
a random key (client's key), and encrypts it, using, say 
the DBS encryption algorithm with the password as the 
20 secret key. The client then saves the encrypted key and 
uses it for login purposes. 

The system uses the client's key for encryption, 
and for setting up a shared key with the server, used for 
authentication. 

25 when a user specifies a bookmark as private, the 

application encrypts the data using, e.g. DBS with the 
client's key. in this way, the server receives encrypted 
data; even the server cannot open this data nor can these 
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data be shared with other members of the community* Note 
that when a client receives an encrypted bookmark, it 
uses its key to decrypt the data. 

Since a single user may install the client on several 
5 machines, there must be a way for users to retrieve all 
their bookmark data (including private items) . Hence, a 
user may export his password to a special encrypted 
password file. Whenever the user wants to install another 
client, he will be prompted to import the password file 
lo containing the encrypted key, The new client can retrieve 
the key provided that the same client password is used. 

System Architecture 

Turning now to Fig, 2, there is shown a block 
diagram of a generalized system architecture in 
15 accordance with one embodiment of the invention. 

As shown, the system (20) has three components: 

1. Server (21) that maintains the community bookmarks 
and manages the system. 

2. Users (Clients) (of which only 22 , 23 and 24 are 
20 shown in Fig. 2) . 

3. Web browsers 22 U) , 23 (±) and 24 a) communicating with 
the respective clients (users) . 

Communication between the client and the server is done 
over TCP/IP; communication inside the client's machine, 
25 between the (possibly multiple) browsers and the client, 
is done using DDE protocol (see below) . The invention is, 
by no means, bound by this specific implementation. 
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BY this embodiment , the system uses the DDE protocol 
to connect the client (e.g. 22) with the web browser (22 1 
and 22 2 ) . Most web browsers implement the DDE (Dynamic 
Data Exchange) protocol for Windows (the DDE service name 
5 for Netscape is NETSCAPE, and for Microsoft™ is EXPLORE) , 
The client uses certain known per se DDE methods to 
exchange data with the browser. The client records the 
URLs visited in each browser windows , even if there are 
several browser windows open. The client will open a URL, 
10 specified by the user, in the browser window that was 
last opened (the active window) . 

This implementation provides the system with an easy way 
to manipulate bookmarks. There is no need to f 'cut M and 
"paste" a URL in order to insert a new bookmark. 

15 The Server 

The server (21) and client use TCP/IP to communicate with 
each other. The server performs the administrative tasks 
required to manage the bookmarks r global attributes, and 
server preferences. The server's user interface is quite 
20 simple. 

The server, as mentioned above, manages the system's 
collection of attributes. The attribute dialog box (user 
interface) shown in Fig- 5 displays all of the system's 
current attributes and includes user interface elements 
25 that enable the following operations: 

• Add: (51) adds a new global attribute 

• Rename: (52) renames a global attribute 

• Delete; (53) deletes a global attribute 
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• Global: (54) modifies a local (private) 
attribute so that it becomes a global one, 

• Join: (55) takes either global or local 
attributes and combines them into one global 

5 attribute. 

The field titles "name" (56) stands for the 

attribute name, own (57) stands for the attribute 

owner. The symbols (G) e-g. (58) , (L) e.g. (59) and 

(S) e.g. (59'} stand for Global, Local and Submit/ 
10 respectively, 

"Global" attributes, which, as specified above, are 
shared among all the community users owned by the server 
(root), whereas "Local" and "Submit" attributes are owned 
15 by the corresponding client (user) . 

The user interface described with reference to Fig, 
5 may be utilized by each user in the community for 
updating attributes of his/her own set. The so updated 
attributes may then be submitted in the (periodic) update 
20 to selected (or all) users in the community, e.g. in 
accordance with the protocol described schematically with 
reference to Fig- 4, 

Turning now to the client, the user interface (shown 
in Figure 6) , is used to access bookmark and add 
25 bookmarks to the community's collection. Its appearance 
resembles the Windows Explorer, The client also enables 
the user to perform tasks such as editing the tree, 
assigning attributes to folders or bookmarks, opening a 
bookmark in the active browser window, and so forth, 

30 

By this specific embodiment, the client user interface 
has the following items: 
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♦ Menu bar (61) - includes options for File, 
Browser, Update, Attributes and Help 

♦ Left window (62) - displays the folder hierarchy 
or "tree". Users can click a folder's name to see 

5 its contents displayed in the right window* 

• Right window (63) - displays the contents 
(either bookmarks or sub-folders) of the folder 
selected in the left window. Folder contents can 
be sorted according to Title, Rating, URL, Date 

10 or Owner . 

• Status bar (64) - runs along the bottom of the 
program window and displays the attributes of the 
bookmark or folder that is currently selected. 



15 By this particular example, there are provided the 
following pre-defined folders : 

• Root (65) - the root of the folder hierarchy or 
"tree" and is titled "username's Bookmarks", Any 
new folder created is displayed beneath this one, 
20 and known per se Hot (66) and History (67) . 

Fig. 6 illustrates the user interfaces where the 
containers (folders) and objects (bookmarks) are 
displayed. 

By the specific example of Fig. 6, the highlighted 
25 URL (entitled "the time zone page" (68)} is inserted to 
the highlighted folder find (69) and is assigned with the 
attributes "find" and "travel" (64), as shown in the 
status bar. The condition that is applied to the bookmark 
and the folder is as before, i.e. a bookmark is displayed 
30 if the attributes thereof are included in those of the 
folder and it does not appear in a sub-folder thereof. 
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The user may create folders having the following 
attributes, for example: 



• Public or shar&d - These are folders that 
5 contain any type of bookmark. 

• Private - These folders include the 
"Private" attribute which ensures that URL 
is dragged into this folder, will be 
marked "private" by default, and kept 

10 encrypted in the database 

• Separator - A folder without attributes, 
i.e. the attribute NOLL is associated 
thereto. This is useful to collect several 
folders which have a common utility but no 

15 common attributes, for example, to collect 

multiple projects under a single 
"projects" separator, or to collect 
several cities under the "travel" 

• Folders that do not yet contain attributes 
20 (and therefore do not contain bookmarks) 



By this specific embodiment, bookmarks are one of 
two types: 

* Public bookmarks - shared with the rest of the 
25 community that is connected to the server. 



Private bookmarks - specified as private and can 
only be viewed from that owner's client. 
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Set or Edit a Bookmark 

To set the attributes of a bookmark, users can do, 
by one embodiment, one of the following: 

1- Drag the bookmark into a folder. The bookmark 
automatically inherits the folder's attributes. 

2. Select a URL (bookmark) so that its name is 
highlighted and then set its attributes using the 
URL Attributes dialog user interface as is displayed 
in the non-limiting example of Figure 7. 

• Add a Title and Description to the URL (71) . 
Users are not required to fill in this 
information, but this description will help the 
community use the bookmark more efficiently, 

m Set the importance rating for a bookmark (72) . Low 
indicates a less important bookmark and High 
indicates a more useful or important site. 

• Set the bookmark to be automatically deleted after 
a specified period of time. (73) 

• Mark a bookmark as Private to prevent it from 
being shared with other users. (74) 



By this specific example, the attributes that were 
25 assigned to the URL (75) are Book and Shopping. 

Whilst the example above focused in shared 
application where information {i.e. bookmarks) is shared 
among users in a community, the "sharing" characteristic 
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is not necessarily obligatory* Thus, for example the 
invention may likewise be applied to a stand-alone mode 
where objects are displayed in containers, through user 
interface, if for example the object and the container 
5 share at least one common attribute. 

In a similar manner objects are dynamically assigned 
with attributed using a user interface, and by specific 
embodiment using the drag and drop operation in the 
manner specified. 

10 Whilst the description above referred to add 

attribute, those versed in the art will readily 
appreciate that updating attributes is not bound to only 
addition of attributes and accordingly other attribute 
updates are supported, such as deleting of attributes. 

15 The invention is likewise not bound to the particular 
updates described above (e.g. attributes, objects, 
assigning of attributes to objects), and accordingly 
other updates may be utilized, all as required and 
appropriate . 

20 In the method claims that follow, alphabetic 

characters and roman symbols used to designate claim 
steps are provided for convenience only and do not imply 
any particular order of performing the steps. 

The invention has been described with a certain 
25 degree o£ particularity, but various alterations and 
modifications may be carried out, without departing from 
the scope of the following Claims: 
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CIAIMS : 

1 1. A method for managing objects for at least one user, 

2 comprising: 

3 (a) providing a set of attributes; 

4 (b) providing a set of containers, each associated with 

5 attributes from among said set; 

6 (a) providing user interface for dynamically assigning 

7 attributes to said objects; 

8 (cl) selectively displaying, through a user interface, at 

9 least one container; an object is displayed in said 

10 container if a condition is met; the condition is 

11 applied to at least the following: at least one of the 
±2 attributes of the container and at least one of the 
13 attribute of the object. 

1 2, The method according to Claim 1, wherein said 

2 assigning, stipulated in step (c) , includes mapping an 

3 object to at least one container and inheriting attributes 

4 thereof* 

1 3. The method according to Claim 1, wherein at least 

2 one of said containers is associated, each, with at least 

3 one essential attribute; said condition includes a 

4 sub-condition that is met if the attributes of said 

5 objects contain said essential attributes. 

1 4„ The method of Claim 1, further adapted to share 

2 objects among community of users; each user is associated 

3 with a respective set of attributes such that at least one 

4 attribute is common to at least two of said users; the 

5 method further comprising executing the following steps 

6 for each user in the community: 

7 (a) providing a user replica that includes objects that 

8 are assigned, each, with at least one attribute ; 

9 (b) providing a set of containers associated, each, 
10 with attributes from among said set; 
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11 (c) providing a user interface for generating an update 

12 in said replica; 

13 (d) submitting the update stipulated in step c to the 

14 replicas of selected users; 

15 (e) receiving at least one update from at least one user 

16 in the community and update said user replica with the 

17 so received update; and 

13 (f) selectively displaying, through a user interface, at 

19 least one container; an object from the replica is 

20 displayed in said container if a condition is met; the 

21 condition is applied to at least the following: at 

22 least one of the attributes of the container and at 

23 least one of the attribute of the object. 

1 5. The method according to Claim 1, wherein said user 

2 interface includes a tree of containers* 

1 6. The method of Claim 5, wherein said condition 

2 further includes a sub-condition: an object is displayed 

3 in the container only if it is not displayed in a 

4 sub-container thereof, 

1 7. The method according to Claims 5, wherein said tree 

2 being Microsoft™ File Explorer like, and wherein said 

3 containers being folders. 

1 8. The method according to Claim 2, wherein said mapping, 

2 includes drag-and-dropping said object to said at least one 

3 container. 

1 9. The method according to Claim 1, 

2 wherein selected objects being, each, a URL bookmark of a 

3 web site, 

1 10, The method according to claim 1, wherein selected 

2 objects being, each, a file. 

1 11. The method according to claim 4, further comprising 

2 the step of: 

3 categorizing selected objects as private; encrypting 

4 said objects with a user unique key- 
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1 12. The method according to claim 4, wherein selected 

2 containers in at least one of said user replicas are 

3 assigned each with a private attribute; any object so 

4 assigned to a container from among said containers is 

5 encrypted using a unique key. 

1 13, The method according to Claim 1, wherein at least 

2 one of said objects further contains object-related-data 

3 selectively displayed in said user interface . 

1 14. The method according to Claim 1, further comprising 

2 the following step: applying at least one of the following 

3 to said set of attributes: adding at least one attribute, 

4 deleting at least one attribute and updating at least one 

5 attribute. 

1 15. A method for sharing objects among community of 

2 users; each user is associated with a respective set of 

3 attributes such that at least one attribute is common to 

4 at least two of said users; the method comprising 

5 executing the following steps for each user in the 

6 community: 

7 (a) providing a user replica that includes objects that 

8 are assigned, each, with at least one attribute; 

9 (b) providing a set of containers associated, each, 
10 with attributes from among said set; 

n (c) providing a user interface for generating an update 

12 in said replica; 

13 (d) submitting the update stipulated in step c to the 

14 replicas of selected users; 

15 (e) receiving at least one update from at least one user 

16 in the community and update said user replica with the 

17 so received update; and 

18 (f) selectively displaying, through a user interface, at 

19 least one container; an object from the replica is 

20 displayed in said container if a condition is met; the 

21 condition is applied to at least the following: at 
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22 least one of the attributes of the container and at 

23 least one of the attribute of the object, 

1 16, The method according to Claim 15, wherein the set of 

2 attributes associated with each user forms part of the 

3 user replica* 

1 17- The method according to Claim 15, wherein said 

2 update includes assigning attributes to said objects. 

1 18. The method according to Claim 15, wherein said 

2 update includes updating an object 

1 19 # The method according to Claim 16, wherein said 

2 update includes updating at least one attribute in said 

3 set; said updating of attribute is selected from the group 

4 that includes: adding an attribute,, deleting an attribute, 

5 editing an attribute, change status of attribute from 

6 Global to Local or -viae versa, joining two or more 

7 attributes into a single attribute. 

1 20, The method according to Claim 4, wherein the set of 

2 attributes associated with each user forms part of the 

3 user replica. 

1 21. The method according to Claim 4, wherein said update 

2 includes assigning attributes to said objects, 

1 22- The method according to Claim 15, wherein said user 

2 interface includes a tree of containers, 

t 23. The method of Claim 22, wherein said condition 

2 further includes a sub-condition: an object is displayed 

3 in the container only if it is not displayed in a 

4 sub-container thereof* 

1 24. The method according to Claims 22, wherein said tree 

2 being Microsoft™ File Explorer like, and wherein said 

3 containers being folders. 

1 25. The method according to Claim 15, wherein selected 

2 objects being, each, a URL bookmark of a web site. 

1 26. The method according to claim 15, wherein selected 

2 objects being, each, a file. 
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1 27. The method according to Claim 15, wherein at least 

2 one of said objects further contains obj ect™related-data 

3 selectively displayed in said user interface. 

1 28. A system for managing objects for at least one user, 

2 comprising a processor and associated memory and display 

3 configured to perform the operations that include: 

4 (a) providing a set of attributes ; 

5 (b) providing a set of containers , each associated with 

6 attributes from among said set; 

7 (c) providing user interface for dynamically assigning 

8 attributes to said objects; 

9 (d) selectively displaying, through a user interface, at 

10 least one container; an object is displayed in said 

11 container if a condition is met; the condition is 

12 applied to at least the following: at least one of the 

13 attributes o£ the container and at least one of the 

14 attribute of the object. 

1 29. A system for sharing objects among community of 

2 users; the system includes at least one server 

3 communicating through a network with users, each being 

4 associated with a processor and associated memory and 

5 display that includes a respective set of attributes such 

6 that at least one attribute is common to at least two of 

7 said users; the respective processor and associated memory 

8 and display are configured to executing the following 

9 steps that includes: 

10 (a) providing a user replica that includes objects that 

11 are assigned, each, with at least one attribute; 

12 (b) providing a set of containers associated, each, 

13 with attributes from among said set; 

14 (c) providing a user interface for generating an update 

15 in said replica; 
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16 (d) submitting through said at least one server the 

17 update stipulated in step c to the replicas of selected 
IB users; 

19 (e) receiving through said at least one server at least 

2 0 one update from at least one user in the community and 

21 update said user replica with the so received update; 

22 and 

23 (f) selectively displaying, through a user interface, at 

24 least one container; an object from the replica is 

25 displayed in said container if a condition is met; the 

26 condition is applied to at least the following: at 

27 least one of the attributes -of the container and at 

28 least one of the attribute of the object. 

1 30. A program storage device readable by machine, 

2 tangibly embodying a program of instructions executable by 

3 the machine to perform method steps for managing objects 

4 for at least one user, comprising: 

5 (a) providing a set of attributes ; 

6 (b) providing a set of containers, each associated with 

7 attributes from among said set; 

a (c) providing user interface for dynamically assigning 

9 attributes to said objects; 

io (d) selectively displaying, through a user interface, at 

n least one container; an object is displayed in said 

12 container if a condition is met; the condition is 

13 applied to at least the following: at least one of the 

14 attributes of the container and at least one of the 

15 attribute of the object. 

1 31 . A computer program product comprising a computer 

2 useable medium having computer readable program code 

3 embodied therein for managing objects for at least one 

4 user, the computer program product comprising: 

5 computer readable program code for causing the 

6 computer to provide a set of attributes ; 
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7 computer readable program code for causing the 

s computer to providing a set of containers, each 

9 associated with attributes from among said set; 

10 computer readable program code for causing the 

11 computer to provide user interface for dynamically 

12 assigning attributes to said objects; 

is computer readable program code for causing the 

14 computer to selectively displaying; through a user 

15 interface/ at least one container; an object is displayed 

16 in said container if a condition is met; the condition is 

17 applied to at least the following: at least one of the 
IS attributes of the container and at least one of the 
19 attributes of the object. 
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ABSTRACT 

A method for managing objects for users including 
providing a set of attributes and a set of containers each 
having attributes from the set. The method farther 
provides a user interface for dynamically assigning 
attributes to the objects. The method further provides for 
selectively displaying, through a user interface / 
containers and objects in the containers. An object is 
displayed in a container if a condition is met. The 
condition is applied to the attributes of the container 
and the attributes of the object. 
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